<template>
  <div class="article-container">
    <el-form ref="articleFromRef" :model="articleFrom" :rules="articleFromRules" label-width="85px">
      <el-form-item label="文章标题:" prop="title">
        <el-input v-model="articleFrom.title" placeholder="请输入文章标题"></el-input>
      </el-form-item>
      <el-form-item label="文章内容:" prop="articleBody">
        <quill-editor
          ref="myQuillEditor"
          v-model="articleFrom.articleBody"
          :options="editorOption"
        />
      </el-form-item>
      <el-form-item label="视频地址:">
        <el-input v-model="articleFrom.videoURL" placeholder="请输入视频地址"></el-input>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'
// 代码高亮的插件
import 'highlight.js/styles/xcode.css'
import hljs from 'highlight.js'

import { quillEditor } from 'vue-quill-editor'
export default {
  name: 'Articles',
  props: {
    articleFrom: {
      type: Object,
      default() {
        return {
          title: '', // 文章标题
          articleBody: '', // 文章正文
          videoURL: '' // 视频地址
        }
      }
    }
  },
  data() {
    return {
      // articleFrom: {
      //   title: '', // 文章标题
      //   articleBody: '', // 文章正文
      //   videoURL: '' // 视频地址
      // },
      editorOption: {
        placeholder: '请在这里输入',
        modules: {
          toolbar: [
            ['bold', 'italic', 'underline', 'strike'], //加粗，斜体，下划线，删除线
            ['blockquote', 'code-block'], //引用，代码块
            // [{ header: 1 }, { header: 2 }], // 标题，键值对的形式；1、2表示字体大小
            [{ list: 'ordered' }, { list: 'bullet' }], //列表
            // [{ script: 'sub' }, { script: 'super' }], // 上下标
            // [{ indent: '-1' }, { indent: '+1' }] // 缩进
            // [{ direction: 'rtl' }], // 文本方向
            // [{ size: ['small', false, 'large', 'huge'] }], // 字体大小
            // [{ header: [1, 2, 3, 4, 5, 6, false] }], //几级标题
            // [{ color: [] }, { background: [] }], // 字体颜色，字体背景颜色
            // [{ font: [] }], //字体
            // [{ align: [] }], //对齐方式
            // ['clean'], //清除字体样式
            ['image', 'video', 'link'] //上传图片、上传视频、链接
          ],
          syntax: {
            highlight: text => {
              return hljs.highlightAuto(text).value // 这里就是代码高亮需要配置的地方
            }
          }
        }
      },
      // 表单校验规则
      articleFromRules: {
        title: [{ required: true, message: '请输入文章标题', trigger: 'blur' }],
        articleBody: [{ required: true, message: '请输入文章正文', trigger: 'blur' }]
      }
    }
  },
  created() {},
  mounted() {
    this.$emit('valid', this.$refs.articleFromRef)
    this.$emit('articleFrom', this.articleFrom)
  },
  components: {
    quillEditor
  }
}
</script>

<style scoped lang='scss'>
.article-container {
  ::v-deep .ql-container {
    height: 180px;
  }
}
</style>
